home *** CD-ROM | disk | FTP | other *** search
Java Source | 1998-12-01 | 4.6 KB | 148 lines |
- /*
- * @(#)HrefButtonArea.java 1.8 98/03/18
- *
- * Copyright (c) 1995-1997 Sun Microsystems, Inc. All Rights Reserved.
- *
- * Sun grants you ("Licensee") a non-exclusive, royalty free, license to use,
- * modify and redistribute this software in source and binary code form,
- * provided that i) this copyright notice and license appear on all copies of
- * the software; and ii) Licensee does not utilize the software in a manner
- * which is disparaging to Sun.
- *
- * This software is provided "AS IS," without a warranty of any kind. ALL
- * EXPRESS OR IMPLIED CONDITIONS, REPRESENTATIONS AND WARRANTIES, INCLUDING ANY
- * IMPLIED WARRANTY OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE OR
- * NON-INFRINGEMENT, ARE HEREBY EXCLUDED. SUN AND ITS LICENSORS SHALL NOT BE
- * LIABLE FOR ANY DAMAGES SUFFERED BY LICENSEE AS A RESULT OF USING, MODIFYING
- * OR DISTRIBUTING THE SOFTWARE OR ITS DERIVATIVES. IN NO EVENT WILL SUN OR ITS
- * LICENSORS BE LIABLE FOR ANY LOST REVENUE, PROFIT OR DATA, OR FOR DIRECT,
- * INDIRECT, SPECIAL, CONSEQUENTIAL, INCIDENTAL OR PUNITIVE DAMAGES, HOWEVER
- * CAUSED AND REGARDLESS OF THE THEORY OF LIABILITY, ARISING OUT OF THE USE OF
- * OR INABILITY TO USE SOFTWARE, EVEN IF SUN HAS BEEN ADVISED OF THE
- * POSSIBILITY OF SUCH DAMAGES.
- *
- * This software is not designed or intended for use in on-line control of
- * aircraft, air traffic, aircraft navigation or aircraft communications; or in
- * the design, construction, operation or maintenance of any nuclear
- * facility. Licensee represents and warrants that it will not use or
- * redistribute the Software for such purposes.
- */
-
- import java.awt.Graphics;
- import java.awt.Image;
- import java.net.URL;
- import java.net.MalformedURLException;
-
- /**
- * An improved "Fetch a URL" ImageArea class.
- * This class extends the basic ImageArea Class to fetch a URL when
- * the user clicks in the area. In addition, special custom highlights
- * are used to make the area look and feel like a 3-D button.
- *
- * @author Jim Graham
- * @version 1.8, 03/18/98
- */
- class HrefButtonArea extends ImageMapArea {
- /** The URL to be fetched when the user clicks on this area. */
- URL anchor;
- /** The highlight image for when the button is "UP". */
- Image upImage;
- /** The highlight image for when the button is "DOWN". */
- Image downImage;
- /** This flag indicates if the "button" is currently pressed. */
- boolean pressed = false;
- /** The border size for the 3-D effect. */
- int border = 5;
-
- /**
- * The argument string is the URL to be fetched.
- * This method also constructs the various highlight images needed
- * to achieve the 3-D effect.
- */
- public void handleArg(String arg) {
- try {
- anchor = new URL(parent.getDocumentBase(), arg);
- } catch (MalformedURLException e) {
- anchor = null;
- }
- if (border * 2 > W || border * 2 > H) {
- border = Math.min(W, H) / 2;
- }
- }
-
- public void makeImages() {
- upImage = parent.getHighlight(X, Y, W, H,
- new ButtonFilter(false,
- parent.hlpercent,
- border, W, H));
- downImage = parent.getHighlight(X, Y, W, H,
- new ButtonFilter(true,
- parent.hlpercent,
- border, W, H));
- }
-
- public boolean imageUpdate(Image img, int infoflags,
- int x, int y, int width, int height) {
- if (img == (pressed ? downImage : upImage)) {
- return parent.imageUpdate(img, infoflags, x + X, y + Y,
- width, height);
- } else {
- return (img == downImage || img == upImage);
- }
- }
-
- /**
- * The isTerminal method indicates whether events should propagate
- * to the areas underlying this one.
- */
- public boolean isTerminal() {
- return true;
- }
-
- /**
- * The status message area is updated to show the destination URL.
- * The graphical highlight is achieved using the ButtonFilter.
- */
- public void highlight(Graphics g) {
- if (entered) {
- g.drawImage(pressed ? downImage : upImage, X, Y, this);
- }
- }
-
- public void enter() {
- showStatus((anchor != null)
- ? "Go To " + anchor.toExternalForm()
- : null);
- repaint();
- }
-
- public void exit() {
- showStatus(null);
- repaint();
- }
-
- /**
- * Since the highlight changes when the button is pressed, we need
- * to record the "pressed" state and induce a repaint.
- */
- public boolean press() {
- pressed = true;
- repaint();
- return true;
- }
-
- /**
- * The new URL is fetched when the user releases the mouse button
- * only if they are still in the area.
- */
- public boolean lift(int x, int y) {
- pressed = false;
- repaint();
- if (inside(x, y) && anchor != null) {
- showDocument(anchor);
- }
- return true;
- }
- }
-
-